Sitthiphol Yuwanaboon

John O'Neal

CS 130

March 9 2021

Readings: Finish 2.2 after PA 2.2.9;

section 2.3;

and section 4.1

Do all of the PA's in section 2.2 after PA 2.2.9 (25 pts.);

section 2.3; and section 4.1

NOTE: I'll download these from zybooks for grading.

**2.1** [5] <COD §2.2> For the following C statement, write the corresponding LEGv8 assembly code. Assume that the C variables f, g, and h, have already been placed in registers x0, x1, and x2 respectively. Use a minimal number of LEGv8 assembly instructions.

```
f = g + (h - 5);
```

**2.2** [5] <COD §2.2> Write a single C statement that corresponds to the two LEGv8 assembly instructions below.

```
ADD f, g, h
ADD f, i, f
```

**2.3** [5] <COD §§2.2, 2.3> For the following C statement, write the corresponding LEGv8 assembly code. Assume that the variables f, g, h, i, and j are assigned to registers  $x_0$ ,  $x_1$ ,  $x_2$ ,  $x_3$ , and  $x_4$ , respectively. Assume that the base address of the

arrays A and B are in registers X6 and X7, respectively.

```
B[8] = A[i - j];
```

**2.4** [10] <COD §§2.2, 2.3> For the LEGv8 assembly instructions below, what is the corresponding C statement? Assume that the variables f, g, h, i, and j are assigned to registers x0, x1, x2, x3, and x4, respectively. Assume that the base address of the arrays A and B are in registers x6 and x7, respectively.

Define instruction fetch, data fetch, instruction execution cycle. Give an example from a load instruction from a Z80 load instruction. (10 pts.)

## 1. Instruction Fetch

The fetch step is the same for each instruction: The CPU sends the contents of the PC to the MAR and sends a read command on the address bus. In response to the read command (with address equal to PC), the memory returns the data stored at the memory location indicated by the PC on the data bus.

- 2. The instruction cycles he cycle that the central processing unit (CPU) follows from boot-up until the computer has shut down in order to process instructions
- 3. Data Fetch
  Fetch is the retrieval of data by a software program, script, or hardware device. After being retrieved, the data is moved to an alternate location or displayed on a screen

## Sample of instruction from a Z80 load instruction

## LD A, 5

This loads the A register with the number 5

## LD D, B

This transfer content of the **B** register to the **D** register

Sitth in Nol Yumandoran EII) Is placed in XO 9 15 placed in x1 M 15 placed in X2 f = q+(h-5) X a temporary register SUB X X X 7 # 5 ADD XOIKIJX3 evaluate g + (h-s) and stare in x = 2.2 ADD F,9,h ~ f=94h ADD f ji f => F = i ff

previous instruction

single ( statement + = i fg +h)

23)

2.4)
LSL = shiff left aparator

LSL ×9, ×0, #3 shiff 3
bits

ADD ×9,86,×9 Adding above millipled who
to hope adding

| LSL      | x 10, x, #3 Shifting variable g by 3 bits                                             |
|----------|---------------------------------------------------------------------------------------|
|          | x(0, x7, x10 Adding the multipled value                                               |
| LOUR     | XO, [xq, #5] according defers of B (7) (copied data stand in mem [vq to)              |
| ADDI     | XII ) X9 H & Starpy data at ACT Inhot  ACF J LA to 2 A CCHIT                          |
| LDVR     | ×9, [811, #0) capiel Midata stoud                                                     |
| ADD      | ×9, [81], #0) capiel thidate stoud un [x11+0] into x9  ×9, ×9, ×0 Adding A(27 +ACFEL) |
| STUR     | x9, [xp, #0] capied data stand<br>in xa to mem [xp, Has                               |
| Hore the | out into B [q] (n xq to Mem [xp, Ho]                                                  |
| So the   | ilina statement<br>BEg] = A[F] +AEP+1]                                                |
|          |                                                                                       |